<template>
  <div class="index">
    <el-button @click="showAdd" class="add" type="success">新增</el-button>
    <Info @update="update" ref="info" :info="info"></Info>
    <List @edit="edit" ref="list"></List>
  </div>
</template>

<script>
import Info from "./Info.vue";
import List from "./List.vue";
export default {
  data() {
    return {
      info: {
        // 弹窗是否显示
        isShow: false,
        // 弹窗类型--新增或者修改
        type: "add",
      },
    };
  },
  components: {
    Info,
    List,
  },
  methods: {
    update() {
      // 发生这个事件 就执行这个函数 此时 需要更新list中的数据
      this.$refs.list.getList();
    },
    edit(data) {
      // 打开新增的弹窗
      this.info.isShow = true;
      this.info.type = 'edit';
      // 给表单赋值
      this.$refs.info.setVal(data);
    },
    showAdd() {
      // 打开新增的弹窗
      this.info.isShow = true;
      this.info.type = 'add';
      // 给表单赋值
      this.$refs.info.setVal({
        pid: 0,
        title: "",
        icon: "",
        type: 1,
        url: "",
        status: 1,
      });
    },
  },
};
</script>

<style>
.index .add {
  margin: 10px;
}
</style>